IBM Docket No. RAL9-00-042

#### In the United States Patent and Trademark Office Patent Application Transmittal

Transmitted herewith for filing is the Patent Application of:

Inventors(s): Brian Mitchell Bass, Jean Louis Calvignac, Anthony Matteo Gallo, Marco C. Heddes,

Michael Steven Siegel, Fabrice Jean Verplanken

For: METHOD AND APPARATUS FOR PROCESSING FRAME CLASSIFICATION

INFORMATION BETWEEN NETWORK PROCESSORS

#### Enclosed are

21 pages of specification, including 18 claims, plus 3 sheets of drawings.
An assignment of the invention to International Business Machines Corporation, Armonk, New York

10504.

A certified copy of a/an

application.

X Declaration and Power of Attorney.

NOT FULLY EXECUTED

PTO-1449 & references

X A return post card

Other:

Filing Fee Calculation (For Other Than Small Entity)

|                                    |       |       |       | Total          | \$690.00 |
|------------------------------------|-------|-------|-------|----------------|----------|
| Multiple Dependent Claim Presented |       |       |       | \$260.00       | \$0.00   |
| Independent claims:                | 3     | 3     | 0     | \$78.00        | \$0.00   |
| Total claims:                      | 18    | 20    | 0     | \$18.00        | \$0.00   |
| Claims Fees:                       | Filed | Limit | Extra | Rate per Extra |          |
| Basic Fee:                         |       |       |       |                | \$690.00 |

Please charge Deposit Account **09-0464** for the **Total** set forth above. The Commissioner is authorized to charge payment of any additional filing fees required under 37 CFR §1.16 and any patent application processing fees under 37 CFR §1.17 or to credit any overpayment to the identified account. A duplicate copy of this sheet is enclosed.

Express Mail Certificate

Express Mail Label No: EK506752086US

Date: April 11, 2000

I hereby certify that I am depositing the papers identified above with the U.S. Postal Service "Express Mail Post Office to Address" service on the above date, addressed to the Commissioner of Patents and Trademarks, Washington, DC 20231

Karen Orzechowski

BY: Joselyn G. brefaber

Joscelyn G. Cockburn

Attorney of Record Reg. No. 27,069

Date: April 11, 2000

IBM Corporation 972/B656 Intellectual Property Law

PO Box 12195

Res. Tri. Park, NC 27709

Telephone: 919-543- 9036

FAX 919-543-3634

transmit wpt 4-7-99

10

15

20

25

## METHOD AND APPARATUS FOR PROCESSING FRAME CLASSIFICATION INFORMATION BETWEEN NETWORK PROCESSORS

Brian M. Bass, Jean L. Calvignac, Anthony M. Gallo, Marco Heddes, Michael S. Siegel and Fabrice Verplanken

#### **BACKGROUND OF THE INVENTION**

The present invention relates to network processors which transfer network data frames between nodes of a network. Specifically, a process and apparatus for supplying frame type information and information identifying the depth of processing of an ingress processor to an egress processor of a network node is described which avoids redundant frame processing.

Communication network systems transfer information between a source and destination in frames which are transferred between different nodes along the network. The frames contain data destined for the user as well as destination information and other information which is needed for later processing downstream. One of the more common devices for transferring frames of data between nodes is the multi-processor switch. The multiprocessor switch is organized as a series of blades for receiving traffic through multiple ports, and for delivering traffic through other ports on the same or different blades of the switch. The blades typically have an ingress processor associated with them which processes incoming frames by correlating the frame destination with an output port, determining from the frame various

10

15

20

parameters which are needed to process the frame, and transferring the processed frame to an egress processor on the same or a different blade. The egress processor may share the same hardware as the ingress processor and run a different set of pico code instructions when it is forwarding frames to an output port of the same blade.

Incoming frames are processed by the ingress processor by parsing the contents of the header, determining a destination for the frame, and then handing off the frame to the appropriate egress processor for processing and forwarding to an appropriate output port. The processing of frames by the ingress and egress processor necessarily requires redundant processing of the frame as it is handed off from the ingress processor to the egress processor. Parsing of header information from the received frame, identifying the frame type as well as other control parameters is part of a frame classification process executed in both the ingress and egress processor. The redundant processing of the frame produces delays in overall device throughput degrading the device performance. The present invention is directed to a system and method which will avoid redundant processing by the egress processor which has previously taken place in the ingress processor.

#### SUMMARY OF THE INVENTION

The present invention provides for the more efficient processing of frames which are being transferred within a network device such as

10

15

20

a network switch. The network device includes an ingress processor which receives the network frames on the input ports. The ingress processor parses the frame parameters and prepares an intra-switch frame for delivery to an egress processor of the switch. The intraswitch frame includes a frame header identifying the type of frame received from the input port, parameters which have already been determined by the ingress processor, a level of processing which has been conducted on the frame and a multicast/unicast control bit. The multicast/unicast control bit identifies to the egress processor whether or not one or more frames are to be prepared for multiple ports on the The intra-switch frame is passed to the egress network switch. processor which is associated with one or more output ports on the network switch, which transfers the frame to a port identified from information contained within the incoming frame. The egress processor completes processing of the frame from program instructions which may have a starting address identified by the header data, reflecting the level of processing carried out on the frame by the ingress processor, and from passed parameters which were previously determined by the ingress processor. In this way, the egress processor need not perform redundant processing of a frame which was previously carried out by the ingress processor.

In one embodiment of the invention, the frame header data is decoded in a hardware classifier logic circuit, while header data is stored in memory by the egress processor, to locate the starting address for the egress processor.

In the other embodiments of the invention, the intra-switch frame header may include other control parameters determined by the ingress processor.

5

10

15

20

#### **DESCRIPTION OF THE FIGURES**

Figure 1 illustrates the architecture of a switch which receives incoming frames and transfers the incoming frame to an egress network processor;

Figure 2 illustrates the frame header data for the intra-switch frame prepared by the ingress processor;

Figure 3 is an illustration of the processor architecture for the egress processor of a network switch; and

Figure 4 illustrates the frame execution by the egress processor for intra-switch frames.

#### DESCRIPTION OF THE PREFERRED EMBODIMENT

Network communications depend upon various components which can connect the segments of a network together such as network switches and bridges. Network switches may be organized in accordance with the architecture shown in Figure 1, wherein data frames transmitted on the network are received on a port of the switch. Each switch has multiple blades 3 which support multiple input ports 0-39, output ports 0-39, and a blade processor. As illustrated in Figure

(RAL9-00-042)

10

15

20

1, input ports 0-39 associated with the first blade have an ingress processor 1 which receives the incoming frames to be routed by the switch. The received frames may be of different formats, depending on the various protocols served by the network switch. Processing of an incoming frame requires that the frame header information be parsed, and control parameters from the frame be derived to determine how the frame is to be processed.

Once the frame has been processed by the ingress processor 1, it can be handed off to the appropriate egress processor 2 which serves a port for transferring the frame to a destination address determined from the incoming frame. The egress processor 2 may be located on a different blade, or may be the ingress processor of the same blade, operating under a different set of pico code instructions.

The present invention takes advantage of the fact that a significant amount of the incoming frame processing which has already taken place in the ingress processor 1 need not be redundantly executed in the egress processor 2. The present invention simplifies processing for the egress processor 2 by passing an intra-switch frame containing data from the originating frame received by the switch, along with a header which contains control data prepared by the ingress processor 1. The control data contained in the intra-switch frame header may identify to the egress processor 2 the type of frame which was received from the network, parameters which were determined during processing by the ingress processor 1,

10

15

20

as well as a level of processing of the received frame by the ingress processor 1 in the form of data for locating a starting address for the egress processor pico code. From this data, it will be possible to identify a starting address for the egress processor 2 which avoids redundant processing of information which was determined by the ingress processor and is now contained in the intra-switch frame header.

The frame header for the intra-switch frame is more particularly shown in Figure 2. Referring now to Figure 2, the frame received from the network input port is shown as 11. A frame header 12 prepared by the ingress processor 1 includes a number of fields which will be used by the egress processor 2 to determine the starting point instruction for processing of the frame as well as additional parameters needed to complete the egress processing. A first field MC includes a one-bit index which identifies whether or not the frame being passed is a multicast or unicast frame. The field SP identifies the source port, the field SB identifies the source blade on which the frame entered the switch, and a parameter LID (lookup identifier) is in the following field.

The MC, variable software header format (VSHF), and frame header extension format (FHEF) are the main fields in the intra-switch frame header used to pass software execution control from the ingress processor 1 to egress processor 2.

When the variable header extension (VHE) field is used to specify control information, the VSHF field is programmed with data to

10

15

20

indicate the data type and format which would appear in the VHE field. When a fixed amount of control information is adequate, the FHEF field indicates the number of bytes in the following FHE field and its format which the egress processor 2 will use during frame processing. The capability of using the variable length header extension field VHE is available for yet unforeseen frame protocols which are to be received over the network to permit control information for such frames.

By decoding data in these fields, the egress processor 2 can begin processing the frame at a starting instruction which takes advantage of the earlier processing performed by the ingress processor. The starting instruction address location can be determined from data in the frame header by a hardware frame classifier as will be described with respect to the egress processor operation. In this way, the egress processor 2 can jump to a starting address which reflects the frame type which was identified by the ingress processor, as well as the level of execution completed by the ingress processor.

In accordance with the preferred embodiment, the frame header 12 of Figure 2 includes one bit in the MC field, two bits in the VFSH field, and two bits in the FHVF field which are exemplary only. The egress processor 2 has associated with it a hardware classifier which detects from the data in these three fields a five-bit code (one bit from the MC field, two bits each from the VFSH and FHVF fields).

10

15

20

The five-bit code identifies at least 32 starting addresses for 32 different sets of pico code to be executed by the egress processor.

The set of instructions identified by the five bit code may thereafter process data contained within the FHE, or VHE fields, as called for by the instructions being executed. This provides the ability for the intra-switch frame header 12 to pass to the egress processor not only starting instruction information to the egress processor to begin processing a set of instructions, but actual parameter values which may have been previously determined by the ingress processor.

Figure 3 illustrates the architectural organization of the egress processor 2 which receives the intra-switch frame. A frame input area FIA 6 defines a series of memory locations which receives the frame passed by the ingress processor. A copy of the first thirty-two bytes of the intra-switch frame shown in Figure 2 is stored in the frame input area (FIA). A copy of the port configuration entry for the interface on which the incoming frame to the switch was received is stored in a port configuration table 7. The port configuration table 7 can be used in a default circumstance, when configuration data in the egress processor turns the hardware classifier off, and execution of the frame begins as in the prior art, without any advance knowledge of the frame type, or the depth of processing previously executed by the ingress processor.

Processor 8 executes an instruction set for processing the data stored in the frame input area (FIA) 6. The Forwarding Enque Area 1 ,

5

10

15

20

(FEA) 9 contains a list of ENQUE parameters, including well known frame alteration parameters (WFA) and flexible frame alteration parameters (FFA). Control structures are created for modifying the frame under control of the egress processor code. Processing of the frame is conventional in that search trees based on keys derived from the contents of the Frame Input Area (FIA) are created, and the results of that search produces other ENQUE parameters, as well as WFA and FFA which are stored in 9. Intermediate values obtained during these calculations are stored in the scratch memory 12 and general purpose registers 10. Hardware assist units 16 are also employed in the process for building the control structures in the Forwarding Enque Area.

In order to make use of the present invention, which seeks to avoid redundant processing by the egress processor 2, a hardware frame classifier 18 logic circuit is provided. The hardware frame classifier (HFC) 18 receives as information the control parameters from the header of Figure 2 on the intra-switch frame. As shown in Figure 2, the MC bit, the FHEF, VSHF bits from the header stored in frame input area FIA 6 are used to identify a starting instruction in processor 8 for commencing processing of the received frame. The decoding of the intra-frame header and selection of the instructions for commencing processing of the frame is shown in Figure 4.

Referring now to Figure 4, the frame header 12 for the intraswitch frame includes in the header a 2-bit extension format field FHEF. The 2-bits in the extension format field FHEF can serve to identify a particular protocol layer in which the incoming frame was received by the switch. The values of the two bits and the identity of the protocol layer can be as set forth in Table 1.

5

#### Table 1:

```
00 = FHE = 0 bytes, default - bridging

01 = FHE = 4 bytes, IPV4

10 = FHE = 4 bytes, SWJUMP

11 = FHE = 4 bytes, encoded stake.
```

10

15

For the data entry 00, no data appears in FHE, such as when the egress processor is doing a bridging function.

For the data entry 01, the routing function is used by the egress processor and the IPV4 address for the next hop is inserted in the FHE field as four bytes of information. Thus, when decoding the header fields, the hardware frame classifier 18 utilizes the 2-bit information to identify the location of the 4 bytes and its meaning.

The data 10 indicates to the hardware frame classifier that four bytes of information within the FHE field is a starting address for the egress processor execution. When the hardware frame classifier 18 indexes the processor to the starting address, subsequent code execution by the processor will recognize that within the FHE are four bytes identifying a jump instruction to which the processor is to begin processing. In this way, starting instructions are not limited to 32, the

20

10

15

20

width of the 5-bit data, but may include others identified from the jump instruction.

The last entry in the table indicates the data entry 11 in the FHEF field identifies four bytes in the FHE field identifying the frame format. The FHE field contains the location of parameters forwarded by the ingress processor which may be used for processing the intraswitch frame having the identified format.

Two other bits which are provided to the hardware frame classifier are contained in the VSHF field. The VSHF field is related to the VHE field in that it specifies a number of bytes which appear in the VHE field in accordance with Table 2.

#### Table 2:

00 = VHE = 0 bytes 01 = VHE = 4 bytes 10 = VHE = 6 bytes 11 = VHE = first byte, VHE length.

These fields will permit further data generated from the ingress processor 1 to be inserted in the VHE field. Further, the data in the VHSF field can identify to the hardware frame classifier the parameter to which the data stored in the VHE field corresponds.

The two bits in the VSHF field can not only be decoded to indicate a particular parameter stored in the VHE field, but identifies the number of bytes in the VHE field containing the parameter. The

(RAL9-00-042)

10

15

20

last entry in Table 2, 11, identifies to the hardware frame classifier 18 that the VHE length data is contained in the first byte of the VHE field.

The fifth bit is from the MC field which identifies the frame as either a multicast or unicast frame to the hardware frame classifier 18.

The hardware frame classifier 18 includes a table which is indexed by the five bits input to the hardware frame classifier 18 from the foregoing MC, VHSF, FHEF fields. The five bits identify a starting address of the pico code instructions stored in the processor 8. Individual instructions following the starting address within the pico processor 8 may, in turn, look to the FHE fields, and VHE fields when the decoded output from the hardware frame classifier 18 points to the relevant set of instructions. For instance, when the FHE field is 10, a jump address is provided in the FHE field, which when the relevant instructions following the entry point of a set of instructions are executed, read the contents of the FHE field to obtain the jump instruction.

Likewise, other instructions which are pointed to as a result of decoding other combination of bits from the MC, VSHF, and FHEF fields by hardware classifier 18 will utilize parameters which have been stored in the FHE field or VHE field by the ingress processor, thus providing to the egress processor ready access to parameters previously computed by the ingress processor.

From the foregoing, the frame data is prepared in the forwarding enque area 9 for delivery to the output of the switch.

(RAL9-00-042)

10

15

20

The egress processor can process multicast frames as well as unicast frames received from the ingress processor. The egress processor is associated with one or more output ports on the network switch and forwards the frame for transfer to a port identified from incoming destination information received from the incoming frame. When the egress processor wants to send a multicast frame out of several ports, it does so by queuing the multicast frame on each port the same way it would have been queued a unicast frame.

Thus, using the foregoing intra-switch frame, it is possible to pass off for execution control from the ingress processor to the egress processor so that redundant processing need not be carried out on the frame.

While the foregoing has been described with respect to a network switch, it should also be recognized that the principles are applicable within any network bridge, or in any network routing situation where frames must be processed a number of times by system components.

The foregoing description of the invention illustrates and describes the present invention. Additionally, the disclosure shows and describes only the preferred embodiments of the invention, but as aforementioned, it is to be understood that the invention is capable of use in various other combinations, modifications, and environments and is capable of changes or modifications within the scope of the inventive concept as expressed herein, commensurate with the above

teachings, and/or the skill or knowledge of the relevant art. The embodiments described hereinabove are further intended to explain best modes known of practicing the invention and to enable others skilled in the art to utilize the invention in such, or other, embodiments and with the various modifications required by the particular applications or uses of the invention. Accordingly, the description is not intended to limit the invention to the form disclosed herein. Also, it is intended that the appended claims be construed to include alternative embodiments.

#### What is Claimed Is:

1. In a network switching system having an ingress processor for receiving incoming frames from a port of a network, and an egress processor having a port through which said frames are delivered, a method for enhancing processor speed by the egress processor comprising:

forming at said ingress processor a header for each frame destined for said egress processor having data for identifying a beginning of a processing sequence for said egress processor; and decoding said data in said header in a hardware frame classifier into a starting address for said egress processor.

- 2. The method for enhancing processing according to claim 1 wherein said frame header includes control information for said egress processor which distinguish said frames as being multicast or unicast.
- 3. The method for enhancing processing according to claim 1 wherein said step of decoding said instructions include indexing an address table in said hardware frame classifier; and executing processing from a starting address space identified by said table of said hardware classifier.

| <ol> <li>The method for enhancing processing according to claim</li> </ol> |
|----------------------------------------------------------------------------|
| 3 wherein processing of said frame begins at a process execution           |
| level determined from a port configuration entry of the interface of the   |
| port said frame was received if a configuration bit of said egress         |
| processor indicates said hardware classifier has been disabled.            |

- 5. The method for enhancing processing according to claim 1 wherein said egress processor creates multiple frames for multiple output ports when said frame header contains multicast data.
- 6. The method for enhancing processing according to claim 1 wherein a parameter is encoded into a field of said frame header by said ingress processor which is read by an instruction executed by said egress processor.
- 7. The method for enhancing processing according to claim 3 wherein said data is located in two fields, the first of which identifies the number of bytes in a second field containing parameters for execution by said egress processor.
- 8. A network switch for enhancing execution of frame classification information comprising:
- an ingress processor for parsing and recovering parameters from said frame and recovering the identity of said frame;

| 5 | said processor being further programmed to create a header for an |
|---|-------------------------------------------------------------------|
| 6 | intra-switch frame identifying said received frame and a level of |
| 7 | processing of said received frame;                                |

an egress processor for receiving said intra-switch frame and for creating a frame for passing to one or more output ports, said processor being programmed to:

execute instructions which follow a starting address for completing processing of said frame; and

forward said processed frame to an output port based on said processing of said frame; and

a hardware frame classifier for determining from said intra-switch frame header said starting address of said instructions which are to be processed.

- 9. The network switch according to claim 8 wherein said hardware frame classifier includes an address table which decodes frame header extension values and variable frame extension values which point to said egress processor starting address location.
- 10. The network switch according to claim 8 wherein said header includes a field which identifies the number of bytes in a variable length field which contain parameters determined by said ingress processor.

- 11. The network switch according to claim 8 wherein said frame header includes a field to identify said received frame as being a multicast frame.
- 12. The network switch according to claim 8 wherein said frame header data is stored in fixed length fields which have a length determined by a length field in said header.
- 13. In a network switch which receives frames of data on a set of input ports and delivers said frames to an output port, a method for improving frame processing time comprising:

partially processing a received frame in an ingress processor which parses said frame parameters and prepares an intraswitch frame for delivery to an egress processor associated with said output port; said ingress processor creating a header for said intraswitch frame having a data for identifying parameters computed by said ingress processor and for identifying a starting address for said egress processor; and

completing processing of said frame in an egress processor which receives said intraswitch frame and passes said processed frame to an output port, said egress processor completing processing from program instructions which have a starting address defined by said header data and from parameters computed by said ingress processor, whereby processing performed by said ingress

- processor is not unnecessarily performed by said egress processor.
  - 14. The method for improving frame processing according to claim 13 wherein said ingress processor encodes in said header data representing a level of processing completed by said ingress processor.
  - 15. The method for improving frame processing according to claim 13 wherein said ingress processor creates multiple fields in said header for indicating the type of frame received, and for indicating the level of processing completed by said ingress processor.
  - 16. The method for improving frame processing according to claim 13 wherein a hardware classifier identifies said starting address from said identifying data in said header.
  - 17. The method for improving frame processing according to claim 16 wherein said hardware classifier locates said address from a table which is indexed by said recovered data.
  - 18. The method for improving frame processing according to claim 13 wherein said egress processor is programmed to detect a multicast bit contained in said frame header which identifies said

frame as being destined to multiple ports.

10

15

## METHOD AND APPARATUS FOR PROCESSING FRAME CLASSIFICATION INFORMATION BETWEEN NETWORK PROCESSORS

#### ABSTRACT OF THE DISCLOSURE

A network device including an ingress processor and egress processor which receives frames of data over the network on an input port, and transfers it to an appropriate output port. The received frame is processed by an ingress processor which prepares an intra-switch frame for delivery to an egress processor serving a relevant output port of the switch. The intra-switch frame includes a frame header having parameters which have been determined by the ingress processor, as well as data indicating an address for the egress processor for beginning processing of the frame. By identifying to the egress processor processing which has already taken place, the egress processor is relieved of any redundant processing of the frame. The egress processor provides a hardware frame classifier which decodes the information contained in the intra-frame header to derive parameters which have been previously computed as well as a starting address for the egress processor. By reducing the amount of redundant processing of the egress processor, total device throughput delay is reduced.

# Sheet 1/3 Brian M. Bass, et al. RAL9-00-042 (JC)



F19 1



2/3 (RAL9-00-042)



3/3 (RAL9-00-042)



Fig 4

#### DECLARATION AND POWER OF ATTORNEY FOR PATENT APPLICATION

As a below named inventor, I hereby declare that:

My residence, post office address and citizenship are as stated below next to my name; I believe I am an original, first and joint inventor of the subject matter which is claimed and for which a patent is sought on the invention entitled:

### METHOD AND APPARATUS FOR PROCESSING FRAME CLASSIFICATION INFORMATION BETWEEN NETWORK PROCESSORS

the specification of which is identified by the attorney (IBM) Docket Number appearing above.

I hereby state that I have reviewed and understand the contents of the above- identified specification, including the claims.

I acknowledge the duty to disclose information which is material to the patentability of this application in accordance with Title 37, Code of Federal Regulations, §1.56.

I hereby claim foreign priority benefits under Title 35, United States Code, §119 of any foreign application(s) for patent or inventor's certificate listed below and have also identified below any foreign application for patent or inventor's certificate having a filing date before that of the application on which priority is claimed:

Prior Foreign Application(s)

Number Country Day/Month/Year Priority Claimed

I hereby claim the benefit (a) under Title 35, United States Code, §119(e) of any U.S. application listed below and identified as a provisional application or (b) under Title 35, United States Code, §120 of any U.S. application listed below and not identified as a provisional application, and, insofar as the subject matter of each of the claims of this application is not disclosed in the prior U.S. application in the manner provided by the first paragraph of Title 35, United States Code, §112, I acknowledge the duty to disclose information material to the patentability of this application as defined in Title 37, Code of Federal Regulations, §1.56 which occurred between the filing date of the prior application and the national or PCT international filing date of this application

Prior U.S. Applications

Serial No. Filing Date Status

I hereby declare that all statements made herein of my own knowledge are true and that all statements made on information and belief are believed to be true; and further that these statements were made with the knowledge that willful false statements and the like so made are punishable by fine or imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful false statements may jeopardize the validity of the application or any patent issued thereon.

#### IBM Docket No. RAL9-00-042

As a named inventor, I hereby appoint the following attorneys and/or agents to prosecute this application and transact all business in the Patent and Trademark Office connected therewith: Daniel E. McConnell, Reg. No. 20,360; Kenneth A. Seaman, Reg. No. 28,113; Joscelyn G. Cockburn, Reg. No. 27,069; Gerald R. Woods, Reg. No. 24,144; John D. Flynn, Reg. No. 35,137; Horace St. Julian, Reg. No. 30,329; Joseph C. Redmond, Jr., Reg. No. 18,753; John E. Hoel, Reg. No. 26,279; Christopher A. Hughes, Reg. No. 26,914; and Edward A. Pennington, Reg. No. 32,588.

Send all correspondence to: Joscelyn G. Cockburn, IBM Corporation 972/B656; PO Box 12195; Research Triangle Park, NC 27709.

| First Inventor:      | Brian Mitchell Bass                       |      |
|----------------------|-------------------------------------------|------|
| Signature:           |                                           |      |
|                      |                                           | Date |
| Residence:           | 4021 Old Sturbridge Drive, Apex, NC 27502 |      |
| Citizenship:         | USA                                       |      |
| Post Office Address: | same as above                             |      |
|                      |                                           |      |
| Second Inventor:     | Jean Louis Calvignac                      |      |
| Signature:           |                                           |      |
|                      |                                           | Date |
| Residence:           | 112 Spring Hollow Lane, Cary, NC 27511    |      |
| Citizenship:         | France                                    |      |
| Post Office Address: | same as above                             |      |
|                      |                                           |      |
| Third Inventor:      | Anthony Matteo Gallo                      |      |
| Signature:           |                                           |      |
|                      |                                           | Date |
| Residence:           | 3308 Corsham Drive, Apex, NC 27502        |      |
| Citizenship:         | USA                                       |      |
| Post Office Address: | same as above                             |      |

### IBM Docket No. RAL9-00-042

| Fourth Inventor:     | Marco C. Heddes                                |      |
|----------------------|------------------------------------------------|------|
| Signature:           |                                                |      |
|                      |                                                | Date |
| Residence:           | 4109 Grand Manor Court #308, Raleigh, NC 27612 |      |
| Citizenship:         | Netherlands                                    |      |
| Post Office Address: | same as above                                  |      |
| Fifth Inventor:      | Michael Steven Siegel                          |      |
| Signature:           |                                                |      |
|                      |                                                | Date |
| Residence:           | 10625 Lowery Drive, Raleigh, NC 27615          |      |
| Citizenship:         | USA                                            |      |
| Post Office Address: | same as above                                  |      |
| Sixth Inventor:      | Fabrice Jean Verplanken                        |      |
| Signature:           |                                                |      |
|                      |                                                | Date |
| Residence:           | 9152 Route de Cagnes<br>06610 La GAUDE, France |      |
| Citizenship:         | France                                         |      |
| Post Office Address: | same as above                                  |      |